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(54) Device and method for motion vector detection 

(57) According to the invention, a motion vector can 
be accurately and efticiently detected with regard to any 
type of images having a variety of characteristkrs. A 
motion vector detection unit detects a motion vector with 
regard to a coding target block on the t^sis of correla- 
tion with a candidate block within a search range. A 
search range storing memory stores pixel data of an 
original search range, and supplies, to the motion vector 
detection unit, pixel data of a search range in accord- 
ance with a memory address. A control unit sets the 
size and the position of the search range on the basis of 
the motion vector and the correlatk)n evaluation value 
supplied from the motion vector detection unit, and gen- 
erates pixel widths in the horizontal and vertical direc- 
tions of the search range and an offset value 
corresponding to the relative position to the original 
search range. An address generation unit generates the 
memory address to be supplied to the search range 
storing memory on the basis of the pixel widths and the 
offset value of the search range generated by the con- 
trol unit. 
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Description 

BACKGROUND OF THE INVENTION 

5 [0001] The present invention relates to motion vector detection used in motion compensative prediction coding, that 
is. a technique of compression coding of digital dynamic image data. 

[0002] As a method of realizing image coding of dynan^c images, time redundancy is reduced by using information 
expressing from which portion of a previous picture a given portion of a current picture is moved (i.e.. a motion vector). 
One of methods of extracting such a motion vector Is designated as a block matching method. 

10 [0003] Figure 1 6 is a diagram for showing the principle of the block matching method. In the block matching method, 
a target frame image (target frame) to be coded is compared with a search frame image (search frame) in which a 
motion vector is searched for. and a block most similar to (namely, having the highest correlation with) a coding target 
b)lock in the target frame (namely, a best match block) is extracted from a search range in the search frame, thereby 
detecting a motion vector. This block matching method is widely used in the motion compensative prediction Ibr image 

IS compression coding. 

[0004] in the block matching method, correlation between one coding target block and plural candidate blocks within 
the search range in the search frame are respectively calculated, and a candidate block having the highest correlation 
is selected as the best match block, so that a positional difference between the best match fcslock and the coding target 
block can be detected as a motion vector. 
20 [0005] As an evaluation value indicating the correlation, an accumulation value of square enors or absolute errors is 
generally used. A difference between a coding target block and a candidate block is smaller as the correlation therebe- 
tween is higher. Therefore, when the accumulation value of square errors or absolute errors is used as the evaluation 
value, the evaluatbn value is smaller as the correlation is higher. 

[0006] A motion vector is detected for the purpose of detecting, in the search frame, a block where a coding amount 
25 can be most effectively reduced in the motion compensative prediction coding. Accordingly, the accuracy in detecting a 
motion vector is one of significant performances of a motion vector detecting device. The motion vector detection is. 
however, a process requiring a particularly large amount of calculation in an image coding algorithm. Therefore, when 
the motion vector detection is realized by hardware, power consunption is disadvantageously large because the proc- 
ess requires a long period of time and a large hardware scale. Furthermore, a real time process of the detection using 
30 software is very difficult to execute at present. Under such drcumstanceSp it is desired to realize motion vector detection 
having high accuracy and high processing efficiency. 

[0007] In some of conventional rnotion vector detecting devices, a search range is made small with regard to an image 
with small movement, so as to shorten a processing time for the detection of a motion vector, and a search range is 
enlarged with regard to an image with large movement. Thus, the processing efficiency can be improved without 

35 degrading the detection accuracy. 

[0008] For example, a motion vector detecting device disclosed in Japanese Laid-Open Patent Publication No. 8- 
32969 comprises means for evaluating correlation with a block in the same position as a process block, means for 
selectively controlling the size of a search range in accordance with the conelation evaluation of the block, and means 
for detecting a motk>n vector by evaluating conelations with respective candidate blocks in the search range. In this 

40 device, the search range is reduced as the correlation of the block in the same position is increased. As a result a 
motion vector can be accurately detected with a small amount of calculation. 
[0009] Such a conventional motion vector detecting device has. however, the following problems: 
[001 0] A picture shot by a camera or the like occasionally includes so-called pan images in which the entire image is 
moved in a given direction. In a pan image, a shot siisstance itself is not changed but the position thereof is moved in 

45 the given direction. 

[001 1] In the aforementioned conventional motion vector detecting device, the size of the search range is set through 
the correlation evaluation with a block in the same position as the process block. Therefore, for example, in a pan image, 
the correlation in the same position is small, and hence, a large search range is inevitably set. Also, prior to the motion 
vector detection, it is necessary to execute the correlation evaluation in the same position, and hence, the process can 
so be disadvantageously complicated. 

SUMMARY OF THE INVENTION 

[0012] The object of the invention is realizing accurate and efficient motion vector detection with regard to images 
55 having a variety of characteristics, and in particular, realizing precise and rapid motion vector detection with regard to a 
pan image. 

[001 3] Specifically, the motion vector detecting device of this invention comprises motion vector detecting means for 
calculating a correlation evaluation value indicating correlation between a coding target block in a target frame and a 
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candidate block within a search range of a search frame and for detecting a motion vector with regard to the coding tar- 
get block on the basis of the correlation evaluation values; original search range storing means for storing pixel data of 
an original search range and for supplying pixel data read in accordance with a given memory address to the motion 
vector detecting means; control meahs for generating a first search width that is a pixel width In the horizontal direction 
5 of the search range, a second search width that is a pixel width in the vertical direction of the search range and an offset 
value indicating a relative position of the search range to the original search range; and address generating means for 
generating the memory address supplied to the original search range storing means on the basis of the first and second 
search widths and the offset value generated by the control means. 

[001 4J Preferably, in tiie motion vector detecting device, the motion vector detecting means supplies, to the control 
10 means, a detected motion vector and a con-elation evaluation value corresponding to the motion vector, and the control 
means generates the first and second search widtiis and the offset value on the basis of the motion vector and ttie cor- 
relation evaluation value supplied by the motion vector detecting means. 

[001 5] Furthermore, the method of this invention of detecting a motion vector with regard to a coding target block com- 
prises a first step of determining whether or not a predetermined area in a target frame includes a portion similar to the 

15 coding target block; a second step of. when it is determined tiiat a similar portion is included in the first step, settir^ a 
first area in the search frame including the similar portion and smaller than tiie predetermined area as a search range 
for motion vector detection; and a third step of, when it Is detennined that a similar portion is not included in the first 
step, setting an area larger than the first area as the search range for motion vector detection. 
[001 6] Preferably, in the metiiod of detecting a motion vector, determination of the first step is made on the basis of a 

20 conelation evaluation value corresponding to a motion vector detected with regard to a range setting reference block 
that is a block in tiie same position as or in the vicinity of tiie cocfing target block in a frame prevkHJS to a target frame, 
and in the second step, a position of the search range is set on the basis of the motion vector detected wHh regard to 
the range setting reference trfock 

[0017] Preferably, in the method of detecting a motion vector, tiie first step includes a step of executing a predeter- 

25 mined pixel calculation on each of a unit area including at least a part of the coding target block aind plural comparison 
areas each having the same size as the unit area and provided in the vicinity of the same position as the coding target 
block in tiie search frame, and determination of the first step Is made on the basis of results of ttie pixel calculation, and 
in tiie second step, a comparison area most similar to the unit area is selected from the plural conparison areas on the 
basis of tiie results of the pixel calculation, and a position of the search range is set on the basis of a position of the 

30 selected comparison area. 

[0018] Moreover, tiie mettiod of detecting a motion vector of tills invention comprises a search range setting step of 
setting a search range for motion vector detection: and a motion vector detecting step of detecting a motion vector wHh 
regard to a coding target block on the basis of correlation witii a candidate block in the search range, wherein the search 
range setting step includes a step of setting a size of the search range on the basis of a conelation evaluation value 

35 conesponding to a motion vector detected witti regard to a range setting reference block tiiat is a bkKk In the same 
position as or in the vicinity of the coding target block in a frame previous to a target frame. 
[0019] Alternatively, the method of detecting a motion vector of ttils Invention comprises a search range setting step 
of setting a search range for motion vector detection; and a motion vector detecting step of detecting a motion vector 
witti regard to a coding target block on the basis of con-elation with a candidate tAock in the search range, wherein the 

40 search range setting step includes a step of setting a position of the search range is set on the basis of a motion vector 
detected witti regard to a range setting reference block that is a block in the same position as or in ttie vicinity of the 
coding target block in a frame previous to a target frame. 

BRIEF DESCRIPTION OF THE DRAWINGS 

45 

[0020] 

Figure 1 is a diagram for illustrating a first embodiment of tiie Invention, and shows timewise continuous tiiree frame 
images conesponding to a panned picture; 
so Figures 2(a) and 2(b) are schematic diagrams for showing examples of a search range for motion vector detection 
according to the first embodiment, wherein Figure 2(a) shows an example of a targe search range and Figure 2(b) 
shows an example of a small search range; 

Figure 3 is a diagram for showing the structure of a motion vector detecting devk:e according to an embodiment of 
the invention; 

55 Figure 4 is a flowchart for showing an operation of a confa-ol unit of the first embodiment; 
Figure 5 is a block diagram for showing tiie configuration of an address generation unit; 
Figure 6 is a diagram for showing a relationship between an original search range and a search range for motion 
vector detection; 
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Figure 7 is a diagram for showing a result of mapping of two-dimensional pixel data of Figure 6 in a one-dimen- 
sional address space of a search range storing memory; 

Figure 8 is a timing chart for showing an operation of the address generation unit of the first emt>odiment; 
Rgure 9 is a flowchart for showing an operation of a control unit according to a modification of the first embodiment: 
5 Figures 10(a) through 10(c) are schematic diagrams for showing examples of a search range for motion vector 
detection according to the modification of the first embodiment; 

Figure 11 is a diagram for showing a relationship between an original search range and a search range for the 
motion vector detection; 

Figure 1 2 is a diagram for showing a result of mapping of two-dimensional pixel data of Figure 1 1 in a one-dimen- 
10 sional address space of a search range storing memory; 

Figure 1 3 is a timing chart for showing an operation of an address generation unit according to the modification of 
the first embodiment; 

Figure 14 is a diagram for showing an exemplified setting of comparison areas in a search frame acconding to a 
second embodiment of the invention; 
IS Figure 1 5 is a flowchart for showing an operation of a control unit of the second emtxxiiment: and 
Figure 1 6 is a diagram for illustrating a block matching method. 

DETAILED DESCRIPTION OF THE INVENTION 

20 EMBODIMENT 1 

[0021] Figure 1 is a diagram for showing timewise continuous three frame images, corresponding to a so-called 
panned picture shot with a camera moved in a leftward direction. When a panned picture is seen in a very short period 
of time. It can be said, in general, that a shot suk)stance is moving at a given ratlB. Accordingly, in a first embodiment. In 

25 detecting a motion vector MV with regard to a coding target block CB in a target frame (frame (1)). a block AB of a 
search frame (frame (0)) in the same position as the coding target block CB is set as a range setting reference block, 
and on the basis of a motion vector BMV detected with regard to the range setting reference block AB and a correlation 
evaluation value BAE corresponding to the motfon vector BMV, the size and the position of a search range are deter- 
mined. In this manner, as is shown in Rgure 1 , a search range for the motion vector detection can be narrowed down 

30 to and set in an area where the image of the coding target t)lock CB is estimated to be present in the search frame. 
Accordingly, a motion vector can be accurately and rapidly detected. 

[0022] Figures 2(a) and 2(b) are schematic diagrams for showing examples of the search range for the motion vector 
detection according to this embodiment. In this embodiment the search range can be in any of two types of sizes. Fig- 
ures 2(a] and 2(b) show examples of the search range for the coding target block CB having a general size (i.e., 1 6 pix- 

35 els in the horizontal direction by 16 pixels in the vertical direction) of an image coding standard such as MPEG. Figure 
2(a) shows a search range of 46 pixels in the horizontal direction by 46 pixels in the vertical direction as an example of 
a large search range and Figure 2(b) shows a search range of 30 pixels in the horizontal direction by 30 pixels in the 
vertical direction as an example of a small search range S. The position of the small search range S is expressed t3y 
using a relative position to the large search range W. In this case, a vector starting at the upper left corner, that is, tiie 

40 search start point of the search range W and ending at the upper left corner, that is, the search start point of tiie search 
range S is defined as an offset (Hoff. Voff), and the position of the search range S is expressed by using offset values 
conesponding to the components of the offset. At this point, for example, when a picture Is a still image and the search 
range S is set in the position of the coding target block CB. the offset values are, as is shown in Figure 2(b): 

45 Hoff e 8 

Voff = 8 

Furtiiermore, a pixel width along the horizontal direction of the search range is designated as a search horizontal (H) 
50 pixel width conesponding to a first search width, and a pixel width along the vertical direction of the search range is des- 
ignated as a search vertical (V) pixel width corresponding to a second search width. 

[0023] Figure 3 is a diagram for showing the structure of a motion vector detecting device of tiiis embodiment. In Rg- 
ure 3. a reference numeral 10 denotes an address generation unit for generating a memory address MA on the basis 
of a search H pixel width, a search V pixel width and an offset, a reference numeral 20 denotes a search range storing 
55 memory corresponding to original search range storing means for staing image data of an original search range, a ref- 
erence numeral 30 denotes a motion vector detection unit for calculating an evaluation value indicating con-elation 
between a coding target block and a candidate block in a search range and for outputting a motion vector corresponding 
to the highest correlation and an evaluation value corresponding to this motion vector, a reference numeral 40 denotes 
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a control unit for determining a search H pixel width, a search V pixel width and an offset on the basis of the motion 
vector and the evaluation value output by the motion vector detection unit 30 and outputting the calculated values to the 
address generation unit 1 0. and a reference numeral 50 denotes a coding target block storing memory for storing image 
data of a coding target block. Here, the original search range is the large search range W of 46 pixels by 46 pixels. 
5 [0024] Figure 4 is a flowchart for showing an operation of the control unit 40. Now, the operation of the control unit 40 
will be described with reference to the flowcfiart of Figure 4 and Rgure 1 . 

[0025] It is herein assumed that the search range for the motion vector detection is to be set with regard to the coding 
target block CB in the target frame. The control unit 40 supplies, to the address generation unit 10. a search H pixel 
width, a search V pixel width and an offset representing the search range and determined on the basis of the motion 
10 vector BMV with regard to the range setting reference bk)ck AB in the search frame and the con-elation evaluation value 
BAE corresponding to the motion vector BMV. 

[0026] In a step S1 . the correlation evaluation value BAE corresponding to the range setting reference block AB is 
compared with a threshold value AEO. When the evaluation value BAE is found to be larger than the threshold value 
AEO as a result of the comparison, it is determined that there is no portion similar to the coding target block CB in a 
75 predetermined area in the search frame because the correlation of the motion vector BMV is small. Therefore, without 
nan-owing down the search range, the large search range W of 46 pixels by 46 pixels, that is the original search range, 
is set as the search range for the motion vector detection (step S2). Specifically, in this case, both the search H pixel 
width and the search V pixel width are defined as "46- and the offset is defined as (0, 0). 

[0027] When the correlation evaluation value BAE corresponding to the range setting reference block AB is not larger 
so than the threshold value AEO, it is determined that there is a portion similar to the cocOng target block CB in the prede- 
termined area in the search frame because the correlation of the motion vector BMV is large. Therefore, the small 
search range S of 30 pixels by 30 pixels is set as the search range for the motion vector detection (step S3). Then, in a 
step S4. the size of the motion vector BMV, i.e., |BMV (x. y)|. of the range setting reference block AB is compared with 
a threshold value MVO. 

25 [0028] When the size of the motion vector BMV is found to be larger than the threshold value MVO as a resuK of the 
comparison, it is determined that the movement of the coding target block CB is large, and the offset is set by using the 
components of the motion vector BMV (step S5). Specifically, the components of the offset (Hoff. VofO are set as fol- 
lows: 

30 Hoffsx-i-8 

Voff = y + 8 

In other words, in this case, both the search H pixel width and the search V pixel width are defined as "30" and the offset 
35 is defined as (x+8. y+8). 

[0029] When the size of the motion vector BMV is not larger than the threshold value MVO, it is determined that the 
movement of the coding target block CB is small and that the image therein is still, and the offset is set at (8. 8). Spe- 
cifically, in this case, both the search H pixel width and the search V pixel width are defined as "30" and the offset is 
defined as (8. 8). 

40 [0030] The address generation unit 10 generates a memory address MA on the basis of the search H pixel width, the 
search V pixel width and the offset output by the control unit 40. The motion vector detection unit 30 detects a motion 
vector with regard to the coding target block CB by using pixel data of the search range read from the search range stor- 
ing memory 20 (step SIO). 

[0031] Figure 5 is a block diagram for showing the configuration of the address generation unit 10, As is shown in 
45 Figure 5, the address generation unit 10 includes an H counter 11 as a first counter for counting a clock, an H compa- 
rator 12 as a comparator for conparing the search H pixel width and the count value of the H counter 11. resetting the 
count value of the H counter 11 when the compared values are the same, and outputting a count-up signal CU. a V 
counter 13 as a second counter for counting the count-up signal CU, a V comparator 14 for comparing the search V 
pixel width and the count value of the V counter 13 and generating an actuation signal for completing the operation of 
so the motion vector detection unit 30 when the compared values are the same, and a memory address converter 15 for 
generating the memory address MA of the search range storing memory 20 on the basis of the offset and the count 
values of the H counter 1 1 and the V counter 1 3. The H counter 1 1 and the V counter 13 are reset in accordance with 
a start signal si^plied by the control unit 40. so that the address generation unit 10 can be actuated. 
[0032] Now, the operation of the address generation unit 10 of Figure 5 will be described with reference to Figures 6 
55 through 8. 

[0033] Figure 6 is a diagram for showing a relationship between an original search range stored in the search range 
storing memory 20 and a search range for the motion vector detection. As is shown in Figure 6, it is herein assumed 
that the search range storing memory 20 stores pixel data of 12 pixels in the horizontal direction by 8 pixels in the ver- 
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tical direction as the original search range, and that a search range determined b/ the search H pixel width of 8. the 
search V pixel width of 6 and the offset of (2. 1) is set as the search range for the motion vector detection. 
[0034] Figure 7 is a diagram resulting from mapping of the twoKiimensional pixel data of Figure 6 in a one-dimensional 
address space of the search range storing memory 20. The address generation unit 10 generates the memory address 
MA to be used for reading the pixel data of the search range for the motion vector detection from the search range stor- 
ing memory 20. Rgure 8 is a timing chart for showing the operation of the address generation unit 10. As is shown in 
Figure 8, when the start signal is input, the H counter 1 1 starts counting the clock. When the count value of the H coun- 
ter 11 becomes equal to a value indicating the search H pixel width, the H counter 12 outputs the count-up signal CU. 
thereby resetting the count value of the H counter 1 1 . The V counter 1 3 counts the count-Mp signal CU. When the count 
. value of the V counter 13 becomes equal to a value indicating the search V pixel width, the V comparator 14 outputs 
the actuation signal. 

[0035] In response to the offset (Hoff, Voff), the memory address converter 1 5 calculates an address SAO as a start- 
ing point of the search range for the motion vector detection on the basis of a pixel width Hmax in the horizontal direc- 
tion and a pixel width Vmax in the vertical direction of the original search range stored in the search range storing 
memory 20. The starting address SAO is obtained by the following formula: 

SAO = Hmax x Voff + Hoff 

[0036] In the case exemplified in Figure €. the starting address SAO is: 

SA0=:12x1-h2=14 

[0037] Then, the memory address converter 1 5 calculates the memory address MA by the following formula: 
MA = SAO + Hmax x ( the count value of the V counter 13 ) 
+ the count value of the H counter 11 

As a result, the memory address MA is varied as is shown in Figure 8. For example, from the starting address SAO up 
to an address corresponding to the search H pixel width, the memory address RflA can be obtained by adding the count 
value of the H counter 1 1 to the starting address SAO as is shown in Rgure 7. In response to the input of a subsequent 
clock, the count value of the H counter 11 is set at 0 and the count value of the V counter 13 is set at 1 . At this point 
the memory address MA Is: 

MA = 14 + 12 x 1 + 0 = 26 

[0038] In this manner, according to this embodiment, a motion vector can be accurately and efficiently detected even 
in a panned picture. 

[0039] In this embodiment, a block of the search frame in the same position as the coding target block is used as the 
range setting reference block. Instead, a block of the search frame in the vicinity of the same position as the coding tar- 
get block can be used as the range setting reference block. Also, a block in the same position or in the vteinity of the 
same position as the coding target block in a frame further preceding the search frame can be used as the range setting 
reference block. 

[0040] Furthermore, although the search range of this emtxxiiment has two types of sizes, the search range can be 
in a larger number of types of sizes. Also, the search H pixel width and the search V pixel width can be made variable, 
with the components of a motion vector with regard to a range setting reference block used as an evaluation Index. 

MODIFICATION OF EMBODIMENT 1 

[0041] In the first embodiment, subsampling can be also adopted. In this case, the control unit 40 inputs to the 
address generation unit 10, in addition to the search H pixel width, the search V pixel width and the offset value, a sub- 
sample number DH in the horizontal direction of the search range as a first subsampie number and a subsample 
number DV in the vertical direction as a second subsample number. 

[0042] Figure 9 is a flowchart for showing the operation of the control unit 40 according to this modification. This flow- 
chart is different from that shown in Figure 4 in specifying whether or not sut)sampling is executed in addition to setting 
the size and the position of the search range. Specifically, in a step S2A for setting the large search range W and in a 
step S5A for setting the small search range S in a position other than the position of the coding target block CB, the 
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execution of subsampling is specified. In a step S6A for setting the small search range S in the same position as the 
coding target block CB. the executing of subsampling is not specified. 

[0043] Figures 1 0(a) through 1 0(c) are schematic diagrams for shewing examples of the search range for the motion 
vector detection according to this modification. In this case, the subsample nurr^er DH in the horizontal direction and 

5 the subsample number DV in the vertical direction are both set at 2. Figure 1 0(a) shows an example of the large search 
range W adopted when the executing of subsampling is specified. Figure 10(b) shows an example of the small search 
range S adopted when the execution of sut>sampling is specified, and Figure 10(c) shows an example of the small 
search range S adopted when the execution of subsampling is not specified. In the step S6A, it is because the move- 
ment of the coding target block CB is determined to be small that the small search range S is set in the same position 

10 as the coding target block CB. In this case, since degradation of the detection accuracy is undesirable, the execution of 
subsampling is not specified as is shown in Figure 10(c). 

[0044] Now, the operation of the address generation unit 10 of this modification will be described with reference to 
Figures 11 through 13. 

[0045] Figure 11 is a diagram for showing the relationship t}etween an original search range stored in the search 
15 range storing memory 20 and a search range for the motion vector detection. It is herein assumed, as is shown in Fig- 
ure 11 . that the search range for the motion vector detection is determined by defining the search H pixel width as 6, 
the search V pixel width as 4. the offset as (0. 0). and both the subsample numbers DH and DV as 2. 
[0046] Figure 12 is a diagram resulting from mapping the two-dimensional pixel data of Figure 11 in a one-dimen- 
sional address space of the search range storing memory 20. 
so [0047] Figure 1 3 is a timing chart for showing the operation of the address generation unit 1 0. In this modification, the 
memory address converter 15 calculates a memory address MA by the following formula: 

MA SAO + Hmax x (tlie count value of the V counter 13) x 

As a result, the memory address MA is varied as is shown in Figure 12. 
30 EMBODIMENT 2 

[0048] In a second embodiment of the invention, plural blocks having the same size as a coding target block are set 
in the search frame in the vicinity of the same position as the coding target tslock, and a predetermined pixel cak:ulation 
is conducted with regard to the coding target block and each of the plural blocks set in the search frame. On the basis 

35 of the results of the calculation, the size and the position of the search range for the motion vector detection are set. 
Herein, an accumulating calculation of pixel data in the block is performed as the predetermined pixel calculation. 
[0049] Figure 14 is a diagram for showing an example of the blocks set in the search frame according to ttiis embod- 
iment. In Figure 14, with regard to a coding target block CB of 16 pixels by 16 pixels as a unit area, nine blocks SBO 
through SB8 each of 16 pixels by 16 pixels are set in the search frame as comparison areas. 

40 [0050] A motion vector detecting device of this embodiment has the structure as is shown in Figure 3 similarly to that 
of the first embodiment. However, the control unit 40 does not receive a motion vector and an evaluation value output 
by the motion vector detection unit 30 but receives image data of each frame instead. 

[0051] Figure 15 is a flowchart for showing the operation of the control unit 40 of the motion vector detecting device 
of this embodiment. First, in a step S21 . with regard to tiie coding target block and each block set in the search frame. 

45 the accumulating calculation of the pixel data of the block is executed. In a step S22. a minimum absolute value SAmin 
of a difference between an accumulation result AC(CB) of the coding target block and an accumulation result AC(SBn) 
(wherein n = 0 tiirough 8) of each block set In the search frame is compared with a threshoM value SAO. When the min- 
imum value SAmin is found to be larger than the threshold value SAO as a result of the comparison, it is determined 
that there is no portion similar to the coding target block CB in a predetermined area in the search frame. Therefore, 

so without nan^owing down the search range, the large search range W of 46 pixels by 46 pixels is set as the search range 
for tiie motion vector detection (step S23). Specifically, in tiiis case, both the search H pixel width and the search V pixel 
width are defined as "46" and tiie offset is defined as (0, 0). 

[0052] When the minimum value SAmin is not larger than the tiireshold value SAO. it is determined that there is a 
portion similar to the coding target block CB in tiie predetermined area in the search frame. Therefore, the small search 
55 range S of 30 pixels by 30 pixels Is set as tiie search range for tiie motion vector detection (step S24). Then, in a step 
825, tiie offset is set so that tiie search range S can be set in the position of a block SBk when tiie absolute value of a 
difference between the accumulation result of tiie block SBk and the accumulation result of the coding target block CB 
is tfie minimum. 



7 



EP0 896 300 A2 



[0053] For example. In the case where the block SBO is set in the same position as the coding target block CB and 
the blocks SB1 through SB8 are set around the block SBO, the offset is set at (0. 0) when the absolute value of a dif- 
ference between the accumulation result of the block SBO and the accumulation result of the coding target block CB is 
the nninlmum. Also, when the absolute value of a difference between the accumulation result of the block SB8 and the 
5 accumulation result of the coding target block CB is the minimum, the offset is set at (16, 16). 

[0054] in this manner, according to this embodiment, the offset is set without using a motion vector detected in a pre- 
vious frame. Therefore, the offset can be set in an initial frame in the motton vector detection. As a result, a motion vec- 
tor can be detected more efficiently than in the first embodiment. 

[0055] Alternatively, with defining a part of the coding target block as a unit area and with setting plural comparison 
10 areas each having the same size as the unit area, a predetermined pixel calculation can be executed on each of these 
areas. Also, the unit area can include an area in the vicinity of the coding target block. Moreover, the unit area can be 
in any shape. 

[0056] As the predetermined pixel calculation, for example, an accumulating calculation of a difference between adja- 
cent pixels, a variance calculation of pixels or a frequency distribution calculation of pixels can be adopted in stead of 
IS the accumulating calculation. In addition, a calcutatbn result can be provided with a weighting in accordance with the 

position of the area. 

[0057] It is noted that the present invention is easily applicable to motion vector detection In accordance with rotation 
or enlargement/reduction of an image. 

so Claims 

1 . A motion vector detecting device comprising: 

motion vector detecting means for calculating a correlation evaluation value indicating correlation between a 
25 coding target block in a target frame and a candidate block within a search range of a search frame and for 

detecting a motion vector with regard to said coding target block on the basis of said coaelation evaluation val- 
ues; 

original search range storing means for storing pixel data of an original search range and for supplying pixel 
data read in accordance with a given memory address to said motion vector detecting means; 

30 control means for generating a first search width that is a pixel width in the horizontal direction of said search 

range, a second search width that is a pixel width in the vertical direction of said search range and an offset 
value indk;ating a relative position of said search range to said original search range; and 
address generating means for generatir^ said memory address supplied to said original search range storing 
means on the basis of said first and second search widths and said offset value generated by said control 

35 means. 

2. The motion vector detecting device of Claim 1 . 

wherein said motion vector detecting means supplies, to said control means, a detected motion vector and 
a correlation evaluation value corresponding to said motion vector, and 

40 

said control means generates said first and second search widths and said offset value on the basis of said 
motion vector and saki correlation evaluation value supplied by sakJ motion vector detecting means. 

3. The motion vector detecting device of Claim 2. 

45 wherein said control means defines a block in the same position as or in the vicinity of said coding target 

block in a frame previous to said target frame as a range setting reference block, and sets a size of said search 
range on the t>asis of a correlation evaluation value oonresponding to said range setting reference block 

4. The motion vector detecting device of Claim 2. 

50 wherein said control means defines a block In the same position as or in the vicinity of said coding target 

block in a frame previous to said target frame as a range setting reference block, and sets a position of sakf search 
range on the basis of a motion vector with regard to sakJ range setting reference block 

5. The motion-vector detecting device of Claim 2. 

55 wherein said control means defines a block in the same position as or in the vicinity of said coding target 

block in a frame previous to said target frame as a range setting reference block, and sets said original search 
range as said search range when con-eiation indicated by a conelation evaluation value corresponding to said 
range setting reference block is comparatively small, while sets a size of said search range to be smaller than a size 
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of said original search range and sets a position of said search range on the basis of a motion vector with regard 
to said range setting reference block when correlation indicated by the correlation evaluation value of said range 
setting reference block is comparatively large. 

5 6. The motion vector detecting device of Claim 1 . 

wherein said offset value corresponds to components of a vector starting at a search start point of said orig- 
inal search range and ending at a search start point of said search range. 

7. The motion vector detecting device of Claim 1 , 
10 wherein said address generating means includes: 

a first counter for counting a clock; 

a comparator for comparing said first search width with a count value of said first counter and. when said first 
search width accords with the count value, resetting the count value of said first counter and outputting a count- 
up signal; 

a second counter for counting said count-up signal; and 

a memory address converter for generating said memory address supplied to said original search range stor- 
ing means In accordance with a predetermined formula on the basis of saki offset value and the count values 
of said first and second counters. 

The motion vector detecting device of Claim 1 , 

wherein saki control means generates, in addition to said first and second search widtfis and said offset 
value, a first subsample number corresponding to a subsampling rate in the horizontal direction of sakl search 
range and a second subsample number conresponding to a subsampling rate in the vertical directbn of said search 
range, and 

sakj address generating means generates said memory address supplied to sakl original search range storing 
means on the basis of said first and second search wkiths, sakJ first and second subsanrpte numbers and saki 
offset value generated by sakl control means. 

A method of detecting a motion vector with regard to a coding target blocK comprising: 

a first step of determining whether or not a predetermined area in a target frame includes a portion similar to 
said coding target block; 

a second step of, when It is determined that a similar portion is included in said first step, setting a first area in 
sakJ search frame including saki similar portion and smaller than saki predetermined area as a search range 
for motk}n vector detectfon; and 

a third step of. when it is determined that a similar portion is not included in saki first step, setting an area larger 
than said first area as saki search range for motion vector detection. 

1 0. The method of detecting a motion vector of Claim 9. 

wherein, determination of sakJ first step is made on the basis of a correiatfon evaluation value corresponding 
to a motion vector detected with regard to a range setting reference block that is a block in the same position as or 
in the vrcinity of said coding target block in a frame previous to a target frame, and 

in saki second step, a position of said search range is set on the basis of said motion vector detected with 
regard to saki range setting reference t)lock. 

The method of detecting a motion vector of Claim 9. 

wherein saW first step includes a step of executing a predetermined pixel calculation on each of a unit area 
including at least a part of said coding target block and plural comparison areas each having the same size as saki 
unit area and provided in the vicinity of the same position as said coding target block in saki search frame, and 
determination of said first step is made on the basis of results of saki pixel calcination, and 

55 in saki secorKi step, a comparison area most similar to said unit area is selected from said plural comparison 

areas on the basis of the results of said pixel calculation, and a position of said search range is set on the basts 
of a position of saki selected comparison area. 
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12. A method of detecting a motion vector comprising: 

a search range setting step of setting a search range for motion vector detection; and 
a motion vector detecting step of detecting a motion vector with regard to a coding target block on the basis of 
5 correlation with a candidate block in said search range. 

wherein said search range setting step, includes a step of setting a size of said search range on the basis of a 
correlation evaluation value con'esponding to a motion vector detected with regard to a range setting reference 
block that is a block in the same position as or in the vicinity of said coding target block in a frame previous to 
a target frame. 

10 

1 3. A method of detecting a motion vector comprising: 

a search range setting step of setting a search range for motion vector detection; and 
a motion vector detecting step of detecting a motion vector with regard to a coding target block on the basis of 
15 correlation witii a candidate block in said search range. 

wherein said search range setting step includes a step of setting a position of said search range on tiie basis 
of a motion vector detected with regard to a range setting reference block that is a block in the same position 
as or in the vicinity of said coding target t^ock in a frame previous to a target frame. 
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offset value of the search range generated by the con- 
trol unit. 
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The Search Division considers that the present European patent application does not comply with ttie 
requirements of unity of invention and relates to several inventions or groups of inventions, namely: 

1. Claims: 1-8, 13 

A motion vector detecting device and method wherein 
means/steps are provided for determining the position of a 
search range on the basis of an original search range and an 
offset value based on global motion; 



2. Claims: 9-11, 12 

A motion vector detecting method wherein steps are provided 
for determining a smaller size of the search range If a 
predetermined area in a target frame Includes a portion 
similar to a coding block, and for determining a larger size 
of the search range if a predetermined area in a target 
frame does not include a portion similar to a coding block. 
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